From 5b6313f16f508882a0ea67716b7dbaa1c6967f04 Mon Sep 17 00:00:00 2001 From: dujinkim Date: Mon, 30 Jun 2025 08:28:13 +0000 Subject: (대표님) 20250630 16시 - 유저 도메인별 라우터 분리와 보안성검토 대응 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../(engineering)/faq/manage/actions.ts | 48 ++++++++++++++++++++++ .../engineering/(engineering)/faq/manage/page.tsx | 38 +++++++++++++++++ 2 files changed, 86 insertions(+) create mode 100644 app/[lng]/engineering/(engineering)/faq/manage/actions.ts create mode 100644 app/[lng]/engineering/(engineering)/faq/manage/page.tsx (limited to 'app/[lng]/engineering/(engineering)/faq/manage') diff --git a/app/[lng]/engineering/(engineering)/faq/manage/actions.ts b/app/[lng]/engineering/(engineering)/faq/manage/actions.ts new file mode 100644 index 00000000..bc443a8a --- /dev/null +++ b/app/[lng]/engineering/(engineering)/faq/manage/actions.ts @@ -0,0 +1,48 @@ +'use server'; + +import { promises as fs } from 'fs'; +import path from 'path'; +import { FaqCategory } from '@/components/faq/FaqCard'; +import { fallbackLng } from '@/i18n/settings'; + +const FAQ_CONFIG_PATH = path.join(process.cwd(), 'config', 'faqDataConfig.ts'); + +export async function updateFaqData(lng: string, newData: FaqCategory[]) { + try { + const fileContent = await fs.readFile(FAQ_CONFIG_PATH, 'utf-8'); + const dataMatch = fileContent.match(/export const faqCategories[^=]*=\s*(\{[\s\S]*\});/); + if (!dataMatch) { + throw new Error('FAQ 데이터 형식이 올바르지 않습니다.'); + } + + const allData = eval(`(${dataMatch[1]})`); + const updatedData = { + ...allData, + [lng]: newData + }; + + const newFileContent = `import { FaqCategory } from "@/components/faq/FaqCard";\n\ninterface LocalizedFaqCategories {\n [lng: string]: FaqCategory[];\n}\n\nexport const faqCategories: LocalizedFaqCategories = ${JSON.stringify(updatedData, null, 4)};`; + await fs.writeFile(FAQ_CONFIG_PATH, newFileContent, 'utf-8'); + + return { success: true }; + } catch (error) { + console.error('FAQ 데이터 업데이트 중 오류 발생:', error); + return { success: false, error: '데이터 업데이트 중 오류가 발생했습니다.' }; + } +} + +export async function getFaqData(lng: string): Promise<{ data: FaqCategory[] }> { + try { + const fileContent = await fs.readFile(FAQ_CONFIG_PATH, 'utf-8'); + const dataMatch = fileContent.match(/export const faqCategories[^=]*=\s*(\{[\s\S]*\});/); + if (!dataMatch) { + throw new Error('FAQ 데이터 형식이 올바르지 않습니다.'); + } + + const allData = eval(`(${dataMatch[1]})`); + return { data: allData[lng] || allData[fallbackLng] || [] }; + } catch (error) { + console.error('FAQ 데이터 읽기 중 오류 발생:', error); + return { data: [] }; + } +} \ No newline at end of file diff --git a/app/[lng]/engineering/(engineering)/faq/manage/page.tsx b/app/[lng]/engineering/(engineering)/faq/manage/page.tsx new file mode 100644 index 00000000..011bbfa4 --- /dev/null +++ b/app/[lng]/engineering/(engineering)/faq/manage/page.tsx @@ -0,0 +1,38 @@ +import { FaqManager } from '@/components/faq/FaqManager'; +import { getFaqData, updateFaqData } from './actions'; +import { revalidatePath } from 'next/cache'; +import { FaqCategory } from '@/components/faq/FaqCard'; + +interface Props { + params: { + lng: string; + } +} + +export default async function FaqManagePage(props: Props) { + const resolvedParams = await props.params + const lng = resolvedParams.lng + const { data } = await getFaqData(lng); + + async function handleSave(newData: FaqCategory[]) { + 'use server'; + await updateFaqData(lng, newData); + revalidatePath(`/${lng}/evcp/faq`); + } + + return ( +
+
+
+
+

FAQ Management

+

+ Manage FAQ categories and items for {lng.toUpperCase()} language. +

+
+ +
+
+
+ ); +} \ No newline at end of file -- cgit v1.2.3